GROUP ART 2172 
AMENDMENT AFTER PINAL Patent 

Amendments to thf. Hi. a m** 

1. (Currently Amended) A method of maintaining consistency of content of an 
object and metadata, said method including the steps of: 

storing said related metadata and a reference to said object in a table of a 
database, said object being stored externally to said database in an object store, said 
object capable of being edited independently of said related metadata, said reference 
used to obtain a handle for directly accessing or manipulating said external object; 

obtaining a version number embedded in an access token in said handle; and 

comparing said embedded version number with a version number of a latest 
committed version of said externally stored object to determine if said handle refers to 
a current version of said externally stored object^ 

permitting direct access to said externally stored nhWt if oa j d hanH i P r . f » ro , n 
a current version of sai d externally stored ohj ert; 

updating said externally stored object while sairf nhj ,w is acrRRRP H 
modifying said metadat a in said database: and 

allowing access to said metadata in said database while said extem g ii y 
object is being up dated 

2. (Original) The method according to claim 1, further including the steps of: 

if said encoded version number and said version number of said latest 
committed version match, comparing a last modification time stamp of said object 
with a last modification timestamp for said latest committed version of said object; 
and 
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if said last modification time stamp of said object matches with said last 
modification timestamp for said latest committed version of said object, permitting 
access to said externally stored object. 

3. (Original) The method according to claim 2, further including the step of, if 
said last modification time stamp of said object does not match with said last 
modification timestamp for said latest committed version of said object, generating an 
error to indicate that said handle refers to stale content in said object. 

4. (Previously Amended) The method according to claim 1, further including the 
steps of updating said object in-place under either DBMS control or file system control 
and linking said metadata and said object under DBMS control. 

5. (Previously Amended) The method according to claim 4, wherein said object is 
capable of being edited independently of said related metadata and uses SQL 
Mediated Object Manipulation (SMOM) for an object that resides external to said 
database. 

6. (Original) The method according to claim 1, further including the step of 
intercepting a native access to said externally stored object or a file system and 
validating the caller's access rights based on a combination of said version number 
and a last modification timestamp for a version of said object. 

7. (Original) The method according to claim 6, wherein said intercepting step is 
carried out using a filter layer of said object store for said stored object. 
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8. (Original) The method according to claim 1, wherein said object store is a local 
file system. 



is a 



9. (Original) The method according to claim 2, wherein said object store 
distributed file system, said object being accessed from a remote file system client. 



10. (Previously Amended) The method according to claim 9, wherein a file 
occurs in the presence of authoritative caching and said comparing steps 
performed at said file system client. 



access 

are 



1 1 . (Original) The method according to claim 10, further including the steps of 
caching the last known version number and the corresponding last modification 
timestamp at said file system client after an access and refreshing said last known 
version number and said corresponding last modification timestamp with latest values 
from a file server the next time one or both of said comparisons fail with the 
previously cached values, in which case said comparing steps are retried with 
refreshed values. 

Claims 12-13 (Cancelled) 

14. (Original) The method according to claim 1 , wherein said version number is 
temporally unique. 
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15. (Previously Amended) The method according to claim 1 1, wherein the last- 
modfficauon-timestamp attribute associated with said object is maintained by said 

object store. 



16. (Original) The method according to claim 1, wherein clock synchronization 
between a database server and a filesystem server is not required. 

17. (Original) The method according to claim 1, wherein said database is rolled 
back to an earlier state. 

18. (Original) The method according to claim 1, wherein said database is a 
replicated version. 

19. (Cancelled) The ui c lh u d aci u idiu b Lu Hum 1, flu Hi, ■ ii idudn^ the ^ v L 
"Plating ^aid ubjctl while A aid objLU U mucnfly mik e d, and 



ac e caaill fe ^ d lac l adaUfui ^aid ubj t Ll udiile jqjd uhj e a u leiii^ updated. 

20. (Currently Amended) An apparatus for maintaining consistency of content of 
an object and metadata related to said object, said apparatus including: 

means for storing said related metadata in a table of a database, said object 
being stored externally to said database in an object store, and said object capable of 
being edited independent of said metadata in ila uat uau . aeti u n m o d e l , said reference 
used to obtain a handle for directly accessing or manipulating said external object; 

means for obtaining a version number embedded in an access token in said 
handle; and 
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means for comparing said embedded version number with a version number of 
a latest committed version of said externally stored object to determine : 
refers to a current version of said externally stored object;. 

version number of H 1, W ^ mjtted^^^ 
said externally stored 

^^^^^ object j, mn|1 . r| |||L 

said metadata in said in fia , d dataW P; an A 



21. (Original) The apparatus according to claim 20, further including: 

means for, if said encoded version number and said version number of said 
latest committed version match, comparing a last modification time stamp of said 
object with a last modification timestamp for said latest committed version of said 

object; and 



means for, if said last modification time stamp of said object matches with said 
last modification timestamp for said latest committed 
access to said externally stored object. 



version of said object, permitting 



22. (Original) The apparatus according to claim 21, further including means for, if 
said last modification time stamp of said object does not match with said last 
modification timestamp for said latest committed version of said object, generating an 
error to indicate that said handle refers to stale content in said object. 
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23. (Previously Amended) The apparatus according to claim 20, further including 
means for updating said object in-place under either DBMS control or file system 
control and linking metadata and said object under DBMS control. 

24. (Previously Amended) The apparatus according to claim 23, wherein said loose- 
transaction update model uses SQL Mediated Object Manipulation (SMOM) for an 
object that resides external to said database. 

25. (Original) The apparatus according to claim 20, further including means for 
intercepting a native access to said externally stored object or a file system and 
validating the caller's access rights based on a combination of said version number 
and a last modification timestamp for a version of said object. 

26. (Original) The apparatus according to claim 25, wherein said intercepting 
means uses a filter layer of said object store for said stored object. 

27. (Original) The apparatus according to claim 20, wherein said object store is a 
local file system. 

28. (Original) The apparatus according to claim 21, wherein said object store is a 
distributed file system, said object being accessed from a remote file system client. 

29. (Original) The apparatus according to claim 28, wherein a file access occurs in 
the presence of authoritative caching and both said means for comparing are 
implemented at said file system client. 
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30. (Original) The apparatus according to claim 29, further including means for 
caching the last known version number and the corresponding last modification 
timestamp at said file system client after an access and means for refreshing said last 
known version number and said corresponding last modification timestamp with 
latest values from a file server the next time with previously cached values, in which 
case both comparing means retry said comparisons with refreshed values. 

Claims 31-32 (Cancelled) 

33. (Original) The apparatus according to claim 20, wherein said version number is 
temporally unique. 

34. (Original) The apparatus according to claim 33, wherein a last-modification- 
timestamp attribute is associated with said object and maintained by said object 
store. 

35. (Original) The apparatus according to claim 20, wherein clock synchronization 
between a database server and a filesystem server is not required. 

36. (Original) The apparatus according to claim 20, wherein said database is rolled 
back to an earlier state. 

37. (Original) The apparatus according to claim 20, wherein said database is a 
replicated version. 
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38. 



(Cancelled) The ap u gia l iM accui ding m daim 23, fmlliu in c luding. 




updated. 



39. (Currently Amended) A computer program for maintaining consistency of 
content of an object and metadata related to said object, said computer program 

including: 

computer code for storing said related metadata and a reference to said object 
in a table of a database, said object being stored externally to said database in an 
object store, and said object capable of being edited independently of said related 
metadata in ft Io u^ l uon^Li u ii m o d e l , said reference used to obtain a handle for 
directly accessing or manipulating said external object; 

computer code for obtaining a version number embedded in an access token in 
said handle; and 

computer code for comparing said embedded version number with a version 
number of a latest committed version of said externally stored object to determine if 
said handle refers to a current version of said externally stored object; 

computer code for if said emb edded v ersion numher nf «rfH oW t m *fnh„ 
with said version number of said latest commits ^ s ion nf Rfl , H n ^ r —; ninr 
access to said externally stored object: 

computer code to up date sa id ob j ect whil e said nhWt i« accessed with™,* 
modifying said related metadata in said database: fln H 
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computer code to acres* >nid related m ^,„ ;~ ^ d dafaWp ^ 
obiect is hpinp np/^tf d 

40. (Original) The computer program according to claim 39, further including: 

computer code for, if .aid encoded version number and said version number of 
said latest committed version match, comparing a last modification time stamp of said 
object with a last modification timestamp for said latest committed version of said 

object; and 

computer code for, if said last modification time stamp of said object matches 
with said last modification timestamp for said latest committed version of said object, 
permitting access to said externally stored object. 

41. (Original) The computer program according to claim 40, further including 
computer code for, if said last modification time stamp of said object does not match 
with said last modification timestamp for said latest committed version of said object, 
generating an error to indicate that said handle refers to stale content in said object. 

42. (Previously Amended) The computer program according to claim 39, further 
including computer code for updating said object in-place under either DBMS control 
or file system control and linking said metadata and said object under DBMS control. 

43. (Previously Amended) The computer program according to claim 42, wherein 
said loose-transaction update model uses SQL Mediated Object Manipulation (SMOM) 
for an object that resides external to said database. 
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44. (Original) The computer program according to claim 39, further including 
computer code for intercepting a native access to said externally stored object or a file 
system and validating the caller's access rights based on a combination of said version 
number and a last modification timestamp for a version of said object. 

45. (Previously Amended) The computer program according to claim 44, wherein 
said intercepting computer code uses a filter layer of said object store for said stored 

object. 

46. (Original) The computer program according to claim 39, wherein said object 
store is a local file system. 

47. (Original) The computer program according to claim 39, wherein said object 
store is a distributed file system, said object being accessed from a remote file system 
client. 

48. (Original) The computer program according to claim 46, wherein a file access 
occurs in the presence of authoritative caching and both said computer codes for 
comparing are carried out at said file system client. 

Claims 49-50 (Cancelled) 

51. (Original) The computer program according to claim 39, wherein said version 
number is temporally unique. 
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52. (Original) The computer program according to claim 49, wherein a last- 
modification-timestamp attribute is associated with said object and maintained by 
said object store. 

53. (Original) The computer program according to claim 39, wherein clock 
synchronization between a database server and a filesystem server is not required. 

54. (Original) The computer program according to claim 39, wherein said database 
is rolled back to an earlier state. 

55. (Original) The computer program according to claim 39, wherein said database 
is a replicated version. 

56. (Cancelled) The method according lu eUiim 12, fmlhu including. 
^ ful u P da ^ ^ o bject wliili ^aid object U tunuiUy link e d, and 

meam fux ^ metadata fui A aid ubju - hilt ^aid ubjiq L. bung 

updated. 

57. (Currently Amended) A computer program product having a computer readable 
medium having a computer program recorded therein for maintaining consistency of 
content of an object and metadata related to said object, said computer program 
product including: 

computer program code means for storing said related metadata and a 
reference to said object in a table of a database, said object being stored externally 



to 
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said database in an object store, said object capable of being edited indcpuiduit 
independently of said related metadata in a Ioual Uamailiuii mudd , said reference 
used to obtain a filename of said object, said filename having an encrypted access 
token having a hash value containing a version number for directly accessing or 
manipulating said external object; 

computer program code means for obtaining a version number embedded in 
said hash value; and 

computer program code means for comparing said embedded version number 
with a version number of a latest committed version of said externally stored object to 
determine if said embedded version number refers to a current version of said 
externally stored object. 



an 
in a 

a 



58. (Currently Amended) A system for maintaining consistency of content of 
object and metadata related to said object, said system including: 

a database storing said related metadata and a reference to said object 
table of a database, said reference used to obtain an encrypted access token having 
hash value with an embedded version number for directly accessing or manipulating 
said object; 

a native object store for storing said object externally to said database, said 
object capable of being edited independently of said related metadata in a loo&c 
t r ansaction mod e l ; 

a database mediator for obtaining said encrypted access token to directly 
access or manipulate said external object; 
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means for obtaining a version number embedded in said hash value of said 
encrypted access token; and 

means for comparing said embedded version number with a version number of 
a latest committed version of said externally stored object to determine if said 
encrypted access token refers to a current version of said externally stored object. 
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